#### 非连续分配的设计目标

- 连续分配的缺点
- □ 分配给程序的物理内存必须连续
  - □ 存在外碎片和内碎片
  - □ 内存分配的动态修改困难
  - □ 内存利用率较低

#### 非连续分配的设计目标

允许一个程序的使用非连续的物理地址空间

非连续分配的设计目标:提高内存利用效率和管理灵活性

允许共享代码与数据

支持动态加载和动态链接

#### 非连续内存分配的实现

- 非连续分配需要解决的问题
  - 如何实现虚拟地址和物理地址的转换
    - ▶ 软件实现 (灵活,开销大)
    - □ 硬件实现 (够用,开销小)
- 非连续分配的硬件辅助机制
  - □ 如何选择非连续分配中的内存分块大小
    - **▶** 段式存储管理 (segmentation)
    - 页式存储管理 (paging)



### 段地址空间

- 进程的段地址空间由多个段组成
  - ■主代码段
  - ▶ 子模块代码段
  - □ 公用库代码段
  - □ 堆栈段(stack)
  - □ 堆数据(heap)
  - □ 初始化数据段
  - □ 符号表等
- 段式存储管理的目的更细粒度和灵活的分离与共享



## 段式地址空间的不连续二维结构



## 段地址空间的逻辑视图



逻辑地址空间

物理地址空间

## 段访问机制

- 段的概念
  - ▶ 段表示访问方式和存储数据等属性相同的一段地址空间
  - ▶ 对应一个连续的内存"块"
  - 若干个段组成进程逻辑地址空间
- 段访问:逻辑地址由二元组(s, addr)表示
  - ▶ s 段号
  - addr 段内偏移



单地址实现方案

"段基址+段内偏移"实现方案

# 段访问的硬件实现





### 页式存储管理

- 页帧 (帧、物理页面, Frame, Page Frame)
  - □ 把物理地址空间划分为大小相同的基本分配单位
- 页面削动物, 如512, 4096, 8192
- - ▶ 把逻辑地址空间也划分为相同大小的基本分配单位▶ 帧和员的大小必须是相同的

## 帧 (Frame)

物理内存被划分成大小相等的帧  $(2^{F}-1, 2^{S}-1)$ 内存物理地址的表示: 二元组 (f, o) f — 帧号 (F 位, 共有2<sup>F</sup> 个帧) (f,o)o — 帧内偏移 (S 位, 每帧有2<sup>S</sup> 字节) 0 物理地址 = f \* 2<sup>S</sup> + o 物理地址 F+S (0,0)物理地址空间

### 基于页帧的物理地址计算实例

- 假定
  - □ 16-bit的地址空间
  - 9-bit (512 byte) 大小的页帧
- 物理地址计算
  - ▶ 物理地址表示 = (3, 6)



物理地址 = 2<sup>S</sup>\*f + o F=7 S=9 f=3 o=6



■ 实际物理地址 =29 \*3+ 6=1536+6=1542

## 页(Page)



## 页式存储中的地址映射



## 页表



#### 页表结构

- 每个进程都有一个页表
  - 每个页面对应一个页表项
  - 随进程运行状态而动态变化
  - **□** 页表基址寄存器(PTBR: Page Table Base Register)

页表项组成

- 帧号: f
- 页表项标志
  - 存在位(resident bit)
  - ▶ 修改位(dirty bit)
  - 引用位(clock/reference bit)



#### 页表地址转换实例



#### 页式存储管理机制的性能问题

- 内存访问性能问题
  - □ 访问一个内存单元需要2次内存访问
  - ▶ 第一次访问: 获取页表项
  - ▶ 第二次访问:访问数据
- 页表大小问题:
  - □ 页表可能非常大
  - □ 64位机器如果每页1024字节,那么一个页表的大小会是多少?
- 如何处理?
  - 缓存 (Caching)
  - 间接 (Indirection) 访问



#### 快表(Translation Look-aside Buffer, TLB)

- 缓存近期访问的页表项
  - TLB 使用关联存储(associative memory)实现,具备快速访问性能
  - ☑ 如果TLB命中,物理页号可以很快被获取
  - ☑ 如果TLB未命中,对应的表项被更新到TLB中



#### 多级页表



## 二级页表实例





#### 大地址空间问题

- 对于大地址空间(64-bits)系统,多级页表变得繁琐.
  - ▶ 比如: 5级页表
  - □ 逻辑 (虚拟) 地址空间增长速度快于物理地址空间
- 页寄存器和反置页面的思路
  - □ 不让页表与逻辑地址空间的大小相对应
  - ▶ 让页表与物理地址空间的大小相对应

#### 页寄存器(Page Registers)

- 每个帧与一个页寄存器(Page Register)关联,寄存器内容包括:
  - 使用位(Residence bit): 此帧是否被进程占用
  - ▶ 占用页号(Occupier): 对应的页号p
  - 保护位(Protection bits)
- 页寄存器示例
  - ▶ 物理内存大小: 4096\*4096=4K\*4KB=16 MB
  - ▶ 页面大小: 4096 bytes = 4KB
  - ▶ 页帧数: 4096 = 4K
  - ▶ 页寄存器使用的空间 (假设每个页寄存器占8字节):
    - **№** 8\*4096=32 Kbytes
  - ▶ 页寄存器带来的额外开销:
    - 32K/16M = 0.2% (大约)
  - ▶ 虚拟内存的大小: 任意

#### 页寄存器方案的特征

- 优点:
  - □ 页表大小相对于物理内存而言很小
  - □ 页表大小与逻辑地址空间大小无关
- 缺点:
  - □ 页表信息对调后,需要依据帧号可找页号
  - 在页寄存器中搜索逻辑地址中的页号

#### 页寄存器中的地址转换

- CPU生成的逻辑地址如何找对应的物理地址?
  - ▶ 对逻辑地址进行Hash映射,以减少搜索范围
  - 需要解决可能的冲突
- 用快表缓存页表项后的页寄存器搜索步骤
  - □ 对逻辑地址进行Hash变换
  - □ 在快表中查找对应页表项
  - □ 有冲突时遍历冲突项链表
  - ▶ 查找失败时,产生异常
- 快表的限制
  - ▶ 快表的容量限制
  - ▶ 快表的功耗限制(StrongARM上快表功耗占27%)

#### 反置页表

- 基于Hash映射值查找对应页表项中的帧号
  - **■** 进程标识与页号的Hash值可能有冲突
  - ▶ 页表项中包括保护位、修改位、访问位和存在位等标识



#### 反置页表的Hash冲突





#### 段页式存储管理的需求

- 段式存储在内存保护方面有优势,页式存储在内存利用和优化转移到后备存储方面有优势。
- 段式存储、页式存储能否结合?

#### 段页式存储管理

■ 在段式存储管理基础上,给每个段加一级页表



#### 段页式存储管理中的内存共享



## 第五讲物理内存管理: 非连续内存分配 第 6 节 RISC-V 页映射机制

#### 向勇、陈渝

清华大学计算机系

xyong,yuchen@tsinghua.edu.cn

2020年5月5日

向勇、陈渝 (清华大学) **第 5 讲** 2020 年 5 月 5 日

#### 回顾



#### • 通过页表来实现隔离与共享

- 运行的应用程序之间的隔离与共享
- 应用与内核之间的隔离与共享
- 便于非连续内存管理
- RISC-V Privileged Architecture Version 1.10 (RV32/64)
- The RISC-V Reader 第 10.6 节





## • RISC-V 对页表的硬件支持

• RISC-V 32 的 Sv32 虚地址与物理地址





## • RISC-V 对页表的硬件支持

• RISC-V 64 的 Sv39 虚地址与物理地址

| 3  | 8 30   | 29     | 21 20  | 12 11       | 0  |
|----|--------|--------|--------|-------------|----|
|    | VPN[2] | VPN[1] | VPN[0] | page offset |    |
|    | 9      | 9      | 9      | 12          |    |
| 55 | 5      | 30 29  | 21 20  | 12 11       | 0  |
|    | PPN[2] | PPN[1] | PPN[0] | page offse  | et |
|    | 26     | 9      | 9      | 12          |    |



- 页表基址: satp in RISC-V 32
- Supervisor Address Translation and Protection (satp) Register



RV32 Supervisor address translation and protection register satp



- 页表基址: satp in RISC-V 64
- Supervisor Address Translation and Protection (satp) Register



 $\ensuremath{\mathsf{RV64}}$  Supervisor address translation and protection register satp



- 页表基址: satp in RV32/64
- Supervisor Address Translation and Protection (satp) Register

|       | RV32             |                                                    |  |  |  |  |
|-------|------------------|----------------------------------------------------|--|--|--|--|
| Value | Name             | Name Description                                   |  |  |  |  |
| 0     | Bare             | No translation or protection.                      |  |  |  |  |
| 1     | Sv32             | Page-based 32-bit virtual addressing.              |  |  |  |  |
| RV64  |                  |                                                    |  |  |  |  |
| Value | Name Description |                                                    |  |  |  |  |
| 0     | Bare             | No translation or protection.                      |  |  |  |  |
| 1-7   | _                | Reserved                                           |  |  |  |  |
| 8     | Sv39             | Page-based 39-bit virtual addressing.              |  |  |  |  |
| 9     | Sv48             | Page-based 48-bit virtual addressing.              |  |  |  |  |
| 10    | Sv57             | Reserved for page-based 57-bit virtual addressing. |  |  |  |  |
| 11    | Sv64             | Reserved for page-based 64-bit virtual addressing. |  |  |  |  |
| 12-15 |                  | Reserved                                           |  |  |  |  |



- 地址保护
- 页表项(page table entry)

| X | W | R | Meaning                              |
|---|---|---|--------------------------------------|
| 0 | 0 | 0 | Pointer to next level of page table. |
| 0 | 0 | 1 | Read-only page.                      |
| 0 | 1 | 0 | Reserved for future use.             |
| 0 | 1 | 1 | Read-write page.                     |
| 1 | 0 | 0 | Execute-only page.                   |
| 1 | 0 | 1 | Read-execute page.                   |
| 1 | 1 | 0 | Reserved for future use.             |
| 1 | 1 | 1 | Read-write-execute page.             |



- 地址保护
- 页表项(page table entry)





- 地址保护
- 页表项(page table entry)



## RISC-V 地址转换



#### • Sv32 in RV32

- 当在 satp 寄存器中启用了分页时,虚拟地址 映射启动。
- 1. satp.PPN 给出一级页表基址,VA[31:22] VPN[1] 给出一级页号,CPU 会读取位于地址 (satp. PPN × 4096 + VA[31: 22] × 4) 的页 表项。
- 2. 该 PTE 包含二级页表的基址,VA[21:12]
   给出二级页号,CPU 读取位于地址 (PTE.
   PPN × 4096 + VA[21: 12] × 4) 的叶节点页表项。
- 3. 叶节点页表项的 PPN 字段和页内偏移 (原始虚址的最低 12 个有效位) 组成了最终 结果: 物理地址就是 (LeafPTE. PPN × 4096 + VA[11: 0])

## RISC-V 地址转换



Sv39 in RV64

- 地址映射要计算三次
- (satp.PPN × 4K + L2 × 8) 的页目录项
- (PTE.PPN  $\times$  4K + L1  $\times$  8) 的二级页目录项
- (LeafPTE.PPN × 4K +L0 x 8) 叶节点页表项
- 叶节点页表项的 PPN 字段  $\times$  4K + Offset

# 第五讲物理内存管理: 非连续内存分配 第 7 节使能 RISC-V 页表

#### 向勇、陈渝

清华大学计算机系

xyong, yuchen @tsinghua.edu.cn

2020年5月5日

# 使能 RISC-V 页表



# OS 配置页表的流程



• 为页表分配物理内存

• 确定映射的物理空间与虚拟空间

• 创建页表

• 设置 satp, 刷新 TLB, 使能页表

Talk is cheap. Show me the code.
(Linus Torvalds)